<template>
  <div class="employees-container">
    <div class="app-container">
      <page-tools>
        <template #left>
          <span>总记录数: 16 条</span>
        </template>
        <template #right>
          <el-button type="warning" size="small">excel导入</el-button>
          <el-button type="danger" size="small" @click="exportToExcel">excel导出</el-button>
          <el-button type="primary" size="small" @click="showDialog=true">新增员工</el-button>
        </template>
      </page-tools>

      <el-card style="margin-top: 10px;">
        <el-table border :data="list">
          <el-table-column label="序号" type="index" />
          <el-table-column label="姓名" prop="username" />
          <!-- 添加显示用户的头像 -->
          <el-table-column label="用户头像">
            <template #default="{row}">
              <img :src="row.staffPhoto" alt="" style="width: 100%;">
            </template>
          </el-table-column>
          <el-table-column label="工号" prop="workNumber" />
          <el-table-column label="聘用形式" prop="formOfEmployment">
            <template #default="{ row }">
              {{ formatHireType(row.formOfEmployment) }}
            </template>
          </el-table-column>
          <el-table-column label="部门" prop="departmentName" />
          <el-table-column label="入职时间" prop="timeOfEntry" />
          <!-- <el-table-column label="账户状态" /> -->
          <el-table-column label="操作" width="280">
            <template #default="{ row }">
              <!-- 方法一: $router.push(`/employees/detail?id=${row.id}-->
              <!-- <el-button type="text" size="small" @click="$router.push(`/employees/detail?id=${row.id}`)">查看</el-button> -->
              <!-- 方法二:路径传参 $router.push(`/employees/detail${row.id}`)-->
              <el-button type="text" size="small" @click="$router.push(`/employees/detail/${row.id}`)">查看</el-button>
              <el-button type="text" size="small">分配角色</el-button>
              <el-button type="text" size="small" @click="hDel(row.id)">删除</el-button>
            </template>
          </el-table-column>
        </el-table>
        <!-- 分页组件 -->
        <el-row type="flex" justify="center" align="middle" style="height: 60px">
          <el-pagination
            :current-page="page"
            :page-sizes="[2, 5, 10, 20]"
            :page-size="size"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
          />
        </el-row>
      </el-card>

      <el-dialog title="新增员工" :visible.sync="showDialog" @close="hClose">
        <!-- 使用组件 -->
        <addOrEdit ref="myEmp" @success="hSuccess" />
      </el-dialog>
    </div>
  </div>
</template>

<script>
import addOrEdit from './empDialog.vue'
import { getEmployeeList, delEmployee } from '@/api/employees'
import employeesEnum from '@/constant/employees'
// 将枚举中的数据遍历转换中 key和value对象 [{id:1,value:'正式'},{id:2,value:'非正式'}]--->{1:正式,2:非正式}
// const hireType = {}
// employeesEnum.hireType.forEach(item => {
//   hireType[item.id] = item.value
// })
const hireType = employeesEnum.hireType.reduce((acc, item) => {
  acc[item.id] = item.value
  return acc
}, {})
export default {
  // 注册组件
  components: {
    addOrEdit
  },
  data() {
    return {
      showDialog: false, // 控制弹层 默认false
      list: [],
      page: 1, // 页码值
      size: 5, // 每页显示数量
      total: 0
    }
  },
  created() {
    this.loadEmployeeList()
  },
  methods: {
    exportToExcel() {
      // 1.发送请求获取需要导出的数据
      // 页面渲染的时候已经发送请求将数据保存到this.list中
      // 2.将数据格式成excel需要的格式
      const { tHeader, result } = this.formatToExicel(this.list)
      console.log(tHeader, 'tHeader')
      console.log(result, 'result')
      // 3.调用admin提供的函数 将数据写到excel中
      // then中回调函数的excel指的是模块对象,就可以使用模块对象调用该模块中暴露的方法
      import('@/vendor/Export2Excel').then(excel => {
        // 2.格式化数据
        // export_json_to_excel将格式化的数据写入到excel中
        excel.export_json_to_excel({
          header: tHeader,
          data: result,
          filename: '嗨嗨', // 设置文件的名称
          autoWidth: true, // 宽度自适应
          bookType: 'xlsx' // 导入的文件类型
        })
      })
    },
    // 格式化excel的数据
    formatToExicel(list) {
      // 1.映射,根据映射找英文的键
      //    中引文的映射对象
      const mapInfo = {
        'id': '编号',
        'password': '密码',
        'mobile': '手机号',
        'username': '姓名',
        'timeOfEntry': '入职日期',
        'formOfEmployment': '聘用形式',
        'correctionTime': '转正日期',
        'workNumber': '工号',
        'departmentName': '部门',
        'staffPhoto': '头像地址'
      }
      // tHeader = ['编号','密码','手机号',....]
      // 1.生成表头
      const one = list[0]
      if (!one) return
      const tHeader = Object.keys(one).map(en_key => {
        return mapInfo[en_key]
      })
      // 2.生成表的内容
      const result = list.map(item => {
        return Object.values(item)
      })
      return { tHeader, result }
    },
    // 删除员工
    hDel(id) {
      this.$confirm('您确定要删除吗?').then(async() => {
        const res = await delEmployee(id)
        console.log(res, 'delEmployee')
        if (this.list.length === 1) {
          this.page--
          if (this.page <= 0) {
            this.page = 1
          }
        }
        if (res.data.code === 10000) {
          this.loadEmployeeList()
        }
      }).catch(error => console.log(error))
    },
    // 重置表单
    hClose() {
      this.$refs.myEmp.resetForm()
    },
    // 新增成功,关闭弹窗,重新刷新页面
    hSuccess() {
      // 将当前页码切换到最后一页
      this.total++
      const maxPage = Math.ceil(this.total / this.size)
      // 切换页码
      this.page = maxPage
      // 关闭弹层刷新页面
      this.showDialog = false
      this.loadEmployeeList()
    },
    // 格式化聘用形式的数据
    formatHireType(value) {
      // vue的值可能是1 || 2
      // console.log(value, 'value111')
      // const obj = employeesEnum.hireType.find(item => item.id === value)
      // console.log(obj)
      // return obj ? obj.value : '未知'
      return hireType[value] || '未知'
    },
    handleSizeChange(val) {
      this.page = 1
      this.size = val
      this.loadEmployeeList()
      console.log(`每页 ${val} 条`)
    },
    handleCurrentChange(val) {
      this.page = val
      this.loadEmployeeList()
      console.log(`当前页: ${val}`)
    },
    // 获取员工的列表
    async loadEmployeeList() {
      try {
        const res = await getEmployeeList(this.page, this.size)
        console.log(res, 'getEmployeeList')
        this.list = res.data.data.rows
        this.total = res.data.data.total
      } catch (error) {
        console.log(error)
      }
    }
  }
}
</script>

<style>

</style>
